home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c14 / ThreadGroup1.java < prev   
Encoding:
Java Source  |  2000-05-25  |  4.7 KB  |  116 lines

  1. //: ThreadGroup1.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // How thread groups control priorities
  50. // of the threads inside them.
  51.  
  52. public class ThreadGroup1 {
  53.   public static void main(String[] args) {
  54.     // Get the system thread & print its Info:
  55.     ThreadGroup sys = 
  56.       Thread.currentThread().getThreadGroup();
  57.     sys.list(); // (1)
  58.     // Reduce the system thread group priority:
  59.     sys.setMaxPriority(Thread.MAX_PRIORITY - 1);
  60.     // Increase the main thread priority:
  61.     Thread curr = Thread.currentThread();
  62.     curr.setPriority(curr.getPriority() + 1);
  63.     sys.list(); // (2)
  64.     // Attempt to set a new group to the max:
  65.     ThreadGroup g1 = new ThreadGroup("g1");
  66.     g1.setMaxPriority(Thread.MAX_PRIORITY);
  67.     // Attempt to set a new thread to the max:
  68.     Thread t = new Thread(g1, "A");
  69.     t.setPriority(Thread.MAX_PRIORITY);
  70.     g1.list(); // (3)
  71.     // Reduce g1's max priority, then attempt
  72.     // to increase it:
  73.     g1.setMaxPriority(Thread.MAX_PRIORITY - 2);
  74.     g1.setMaxPriority(Thread.MAX_PRIORITY);
  75.     g1.list(); // (4)
  76.     // Attempt to set a new thread to the max:
  77.     t = new Thread(g1, "B");
  78.     t.setPriority(Thread.MAX_PRIORITY);
  79.     g1.list(); // (5)
  80.     // Lower the max priority below the default
  81.     // thread priority:
  82.     g1.setMaxPriority(Thread.MIN_PRIORITY + 2);
  83.     // Look at a new thread's priority before
  84.     // and after changing it:
  85.     t = new Thread(g1, "C");
  86.     g1.list(); // (6)
  87.     t.setPriority(t.getPriority() -1);
  88.     g1.list(); // (7)
  89.     // Make g2 a child Threadgroup of g1 and
  90.     // try to increase its priority:
  91.     ThreadGroup g2 = new ThreadGroup(g1, "g2");
  92.     g2.list(); // (8)
  93.     g2.setMaxPriority(Thread.MAX_PRIORITY);
  94.     g2.list(); // (9)
  95.     // Add a bunch of new threads to g2:
  96.     for (int i = 0; i < 5; i++)
  97.       new Thread(g2, Integer.toString(i));
  98.     // Show information about all threadgroups
  99.     // and threads:
  100.     sys.list(); // (10)
  101.     System.out.println("Starting all threads:");
  102.     Thread[] all = new Thread[sys.activeCount()];
  103.     sys.enumerate(all);
  104.     for(int i = 0; i < all.length; i++)
  105.       if(!all[i].isAlive())
  106.         all[i].start();
  107.     // Suspends & Stops all threads in 
  108.     // this group and its subgroups:
  109.     System.out.println("All threads started");
  110.     sys.suspend(); // Deprecated in Java 1.2
  111.     // Never gets here...
  112.     System.out.println("All threads suspended");
  113.     sys.stop(); // Deprecated in Java 1.2
  114.     System.out.println("All threads stopped");
  115.   }
  116. } ///:~